# stichting mathematisch centrum



AFDELING INFORMATICA (DEPARTMENT OF COMPUTER SCIENCE)

IW 227/83

APR1L

J.A. BERGSTRA & J.W. KLOP

A PROOF RULE FOR RESTORING LOGIC CIRCUITS

Preprint

## kruislaan 413 1098 SJ amsterdam

Printed at the Mathematical Centre, Kruislaan 413, Amsterdam, The Netherlands.

The Mathematical Centre, founded 11 February 1946, is a non-profit institution for the promotion of pure and applied mathematics and computer science. It is sponsored by the Netherlands Government through the Netherlands Organization for the Advancement of Pure Research (Z.W.O.).

A proof rule for restoring logic circuits \*)

by

J.A. Bergstra & J.W. Klop

## ABSTRACT

An axiomatic semantics is given for restoring logic circuits, both statically and dynamically. As an example the Muller C-element is discussed in detail. It is shown that a consistent circuit reacts in an unambiguous way on new inputs.

KEY WORDS & PHRASES: switching theory, Muller C-element, restoring logic, axiomatic semantics

<sup>\*)</sup> This report will be submitted for publication elsewhere.

## INTRODUCTION.

A perfect switch (in the notation of REM [6,7]) is a logic component connecting three wires:

The switch S(a,b;c) connects a and b if the voltage of c is high (1) and disconnects a and b if c's voltage is low (0); the switch S(a,b;-c) connects a and b if c has voltage 0 and disconnects them if c has voltage 1.

A circuit is a configuration of wires and switches, with several wires connected to constants 0 or 1. An interesting example is the Muller C-circuit (see REM [6] for a discussion). This circuit has a memory capacity of one bit.



In stable states the wires of a circuit will have voltages 0 and 1. Some wires then, preferably including the ones that are used as outputs, will be restoring in the sense that the circuit keeps their voltages firmly at 0 or 1.

To decide which wires are indeed restoring is very much a matter of the physical implementation of the circuit. Further the voltages of certain wires may be changed thus invoking a process of change throughout the circuit. Describing this is principally a matter of physics as well. Yet, in the words

of MEAD & CONWAY [4],p.68: "It is important to simplify our mental model of integrated circuitry, so as to more quickly and easily analyze or explain the the function of a given circuit, and more easily visualize and invent new circuit structures without drifting too far away from physically realizable and workable solutions."

The present aim is to find an <u>axiomatic semantics</u> of circuits by providing proof rules about restoring logic and circuit dynamics. Viewed mathematically, the rules are plausible, and a semantical theory about much more complex circuits can probably be based on them (that theory must describe clocks, timing and communication).

In HOPCROFT & ULLMAN [1] p.46 an exercise (2.1) about analyzing a circuit occurs. The analysis made there (on p.52) is inconsistent with ours; the proof rules we offer reject that circuit as being inconsistent.

Of course a typical question might now be posed. For which operational <u>semantics</u> are these axioms and rules sound and complete? We have not the slightest idea on how to find a plausible semantics underlying these proof rules, apart from systems of partial differential equations that defeat any analysis.

It must be mentioned that classical switching theory (see e.g. MILLER [5], or KOHAVI [3] Chapter 11) contains much information about similar types of circuits (viz. asynchronous sequential circuits). Our axiomatic semantics might be new however.

This work has been inspired by reading M. REM's paper [6]. There REM explores formal semantics for circuits, useful as a basis for a theory of silicon compilation.

The structure of the remainder of this paper is as follows:

- 1. Preliminary definitions.
- 2. Restoring logic circuits.
- 3. Circuits subject to changing inputs.
- 4. An example in detail: the Muller C-circuit.

Appendix: Inputs and outputs.

References.

## 1. PRELIMINARY DEFINITIONS

In this section we will give the basic definitions of <u>circuits</u>, <u>subcircuits</u>, and labeled circuits. Our definition of 'circuit' is (adapted) from REM [6].

- 1.1. DEFINITION. A circuit C is
- (i) a graph (consisting of a set of  $\underline{nodes}$  {a,b,c,...} and some  $\underline{arcs}$  between the nodes), such that
- (ii) each arc is labeled by "a" or "-a" for some node named a,
- (iii) together with a specification of two disjoint subsets  ${\tt C0}$ ,  ${\tt C1}$  of the set of nodes.

1.2. EXAMPLE. (i) a 
$$\bullet$$
 b b (ii) a0  $\bullet$  a (iii) a0  $\bullet$  c b c  $\circ$  d1 (iv)  $\bullet$   $\bullet$  c  $\circ$  d1 a b c1 d e b f0

In examples (ii),(iii), (iv) the nodes in CO are designated by writing O at that place, likewise for CI. Note that the circuit graphs may be disconnected and may have multiple arcs between a pair of nodes.

1.3. <u>NOTATION</u>. (i) Henceforth the nodes of circuit C will be called <u>wires</u>; they form the set W(C). The arcs will be called <u>switches</u>; S(C) is the set of switches. A switch between  $a,b \in W(C)$ , labeled by  $c \in W(C)$ , is named S(a,b;c). Likewise S(a,b;-c) denotes the switch between a,b labeled by -c.

(It will be clear from the sequel that circuits containing more than one switch S(a,b;c) for fixed a,b,c are redundant. That is, we may assume that for each  $a,b,c\in W(C)$  there is at most one S(a,b;c). Likewise for S(a,b;-c).) Note that S(a,b;c) and S(b,a;c) denote the same switch.

(ii) To conform more to our intuitions, we will (in diagrams) not represent circuits as graphs but as networks where the wires are indeed wires and where as in REM [6] switches are denoted as follows:

1.4. <u>EXAMPLE</u>. The circuits of Example 1.2 are now represented by the diagrams





- 1.5.  $\underline{\text{DEFINITION}}$ . C' is called a  $\underline{\text{subcircuit}}$  of C, notation: C' $\subseteq$  C, iff
- (i)  $W(C') \subseteq W(C)$  and  $S(C') \subseteq S(C)$ ,
- (ii)  $S(a,b;(-)c) \in S(C') \implies a,b,c \in W(C')$  (every switch in the subcircuit C' is supported by wires in C'),
- (iii)  $C'O \subseteq CO \cap W(C')$  and  $C'1 \subseteq C1 \cap W(C')$ .
- 1.6. EXAMPLE. In the NOR-circuit of Example 1.4(iv) the heavily drawn part, consisting of  $\{a,c,e,f\}$ ,  $\{S(e,f;a)\}$  is a subcircuit. (Note that it contains two separate parts.) Furthermore,  $C'O = \emptyset$  and  $C'I = \{c\}$ , if C' is the subcircuit.



- 1.7. DEFINITION of labeled circuits.
- (i) The set of <u>labels</u> is  $\{0,1,0,1\}$ . Here 0 and 1 are called 'restoring 0' and 'restoring 1'.
- (ii) A labeling of a circuit C is a map L:  $W(C) \rightarrow \{0,1,0,1\}$ .
- A labeled circuit C is a pair (C,L) where L is a labeling of C.
- (iv) Let (C,L) be a labeled circuit. The <u>weakening</u> of L, written L, is the labeling defined by

$$L^{-}(a) = 0$$
 if  $L(a) = 0$  or  $L(a) = 0$   
 $L^{-}(a) = 1$  if  $L(a) = 1$  or  $L(a) = 1$ .

- (iii) (C',L') is a <u>labeled subcircuit</u> of the labeled circuit (C,L) iff  $C'\subseteq C$  and  $L' = L \cap S(C')$  (L restricted to S(C')).
- (v) A labeling L of the circuit C is correct iff
  - (1)  $L^{-}(a) = 0$  for all  $a \in C0$  $L^{-}(a) = 1$  for all  $a \in C1$ ,
  - (2) for every  $S(a,b;c) \in S(C)$ :  $L(c) = 1 \Rightarrow L(a) = L(b)$ for every  $S(a,b;-c) \in S(C)$ :  $L(c) = 0 \Rightarrow L(a) = L(b)$ .

## 1.8. EXAMPLE.



Diagram (a) exhibits a correct labeling, while (b) does not.

### 2. RESTORING LOGIC CIRCUITS

We shall now present a proof system called RCL (for  $\underline{\text{Restoring Circuit Logic}}$ ) which is designed to prove statements of the form

(likewise for al). Often the subscript RCL will be omitted. Here it is important that L is required to be a  $\underline{\text{correct}}$  labeling of the circuit C under consideration.

The proof system RCL will be used to derive, from a given correct labeling L of C, a stable labeling (as defined below in Definition 3.3).

The system RCL is built as a 'Natural Deduction' proof system and has the following axioms and rules:

I. Axioms: a0 if 
$$a \in C0$$
a1 if  $a \in C1$ .

II. Switch rules:
$$\frac{a1}{b1} \frac{c1}{s} s(a,b;c)$$

$$\frac{a0}{b0} \frac{c1}{s} s(a,b;c)$$

$$\frac{a1}{b0} \frac{c0}{s} s(a,b;-c)$$

$$\frac{a0}{b0} \frac{c0}{s} s(a,b;-c)$$
III. Assumption rules:

This rule enables us to assume that al will be strengthened to a1. This

assumption is marked by '\*', and in the next rule we have the means of discharging the assumption.

## IV. Restoring logic rule:

is a proof, then  $\frac{al}{al} *$  is a proof.  $\frac{al}{al} *$  is a proof.  $\frac{al}{al} *$  al

(and likewise with 1,1 replaced by 0,0)

Here P must be nonempty; that is, the two displayed occurrences of 'al' may not coincide. Further, it is allowed to discharge (i.e. crossing out '\*') all occurrences of  $\frac{al}{al}$  \* simultaneously.

A proof P is assumption rule free if it contains no undischarged '\*'. If P has the form, say,



where a0, b1 are axioms and P is assumtion rule free, we may write  $c1,d0,e1 \vdash f0$ .

Finally, if L is a <u>correct</u> labeling such that L(c) = 1, L(d) = 0, L(e) = 1, we may write

To ease some formulations, we will also write  $L \vdash pi \text{ if } L(p) = i, i \in \{0,1,0,1\}$ .

- 2.1. REMARK. Note that it is not possible to give 'redundant' proofs; e.g.  $\frac{a\hat{1}}{a\hat{1}}$  is not allowed.
- 2.2. EXAMPLES. (i) 'NOT' is the circuit



hence  $b0 \vdash c1$ . Likewise  $b1 \vdash c0$ .



(ii) Let C be 
$$1 - b$$
 and let L(b) = 1; so L is correct.  
Now  $\frac{b1}{b1} * a1$  hence  $\frac{b1}{b1} * a1$ . Therefore  $b1 - b1$ .

(iii) Let C be

and let L(c) = L(d) = 1. Then

$$\begin{array}{c|c}
\underline{a1} & \underline{d1} \\
\underline{c1} & \underline{b1}
\end{array}$$

Hence dl |- d1.

(iv) Let C be



Then cl,el  $\mid$ - e1,c1,d1. E.g.:

- 2.3. <u>REMARK</u>. Note that the proof system RCL only <u>restores</u> values 0,1. It is not possible to <u>change</u> values 0 to 1 or 1 to 0. (In the next section this will be possible, however.)
- 2.4. <u>DEFINITION</u>. Let (C,L) be a correctly labeled circuit. Then the RCL-closure of L, notation  $\overline{L}$ , is defined by

$$L \mid_{\overline{RCL}} ai \iff \overline{L}(a) = i, \text{ for all } a \in W(C) \text{ and } i \in \{0, 1, 0, 1\}.$$

Since L is correct,  $\overline{L}$  is uniquely determined. (For, in  $(C,\overline{L})$  some of the a0, bl in (C,L) are 'strengthened' to a0, bl; values do not change sign.)

2.5. <u>DEFINITION</u>. (C,L) is an <u>everywhere restoring labeled circuit</u> if L is correct and L:  $W(C) \rightarrow \{0,1\}$ .

Note that if (C,L) is everywhere restoring, then  $L = \overline{L}$ . (The reverse is not true: consider e.g. the circuit C in Example 2.2(ii) with L(b) = 0 and L(a) = 1.)

## 3. CIRCUITS SUBJECT TO CHANGING INPUTS

We will now describe the <u>dynamic behaviour</u> of a circuit C, i.e. what happens after a change of the values at some 'input ports'. This means that CO, C1 are modified. Since the circuit may have memory capacity (internal states), as is the case e.g. in the Muller C-circuit (see next section), the 'old' labeling has to be taken into account during such a modification. However, combining the modification of the inputs with the old labeling will, in general, result in an <u>incorrect</u> labeling. To describe these transformations of incorrectly labeled circuits we use a <u>reduction system</u> which closely resembles and is based on the proof system RCL in Section 2. The objective is that this reduction system enables us to 'reduce' the circuit, starting from a possibly incorrect labeling and via possibly incorrect intermediate labelings, to a 'stable' final labeling, which is then the result of the input modification:

$$(C,L) \rightarrow (C,L') \rightarrow (C,L'') \rightarrow \ldots \rightarrow (C,L_{final}).$$

We will assume that after an input modification the old labeling L lingers on in weakened form, that is, as L. First we define the reduction system.

3.1. <u>DEFINITION</u>. Consider the class of labeled circuits (C,L) where C is fixed and L is arbitrary (and possibly incorrect). On this class of labelings of C a relation " $\rightarrow$ ", called reduction, will be defined as follows.

First we define in (1), (2), (3) below the reduction relation on labeled subcircuits (C',L') of (C,L). Such (C',L') as in the LHS's of (1), (2), (3) will be called <u>redexes</u>, and may be conceived as 'elementary' parts which are candidates for reduction.

## (1) Input reduction rules.

$$0 \xrightarrow{i} 0 \xrightarrow{0} (i = 0,1)$$

$$1 \xrightarrow{i} 1 \xrightarrow{1} (i = 0,1)$$

(2) Switch reduction rules.

(3) Restoring logic reduction rule.

Let (C',L') be a <u>correctly</u> labeled subcircuit. (So  $\overline{L'}$  is defined, by Definition 2.3.) Suppose  $L' \neq \overline{L'}$ . Then:

$$(C',L') \longrightarrow (C',\overline{L'}).$$

(4) Subcircuit rule. If  $(C',L')\subseteq (C,L)$  and  $(C',L')\longrightarrow (C',L'')$ , then  $(C,L)\longrightarrow (C,L[L''/L']).$ 

Here L[L''/L'] is L where L' is replaced by L'', i.e.:

$$L[L''/L'](a) = \begin{cases} L''(a) & \text{if } a \in W(C') \\ L(a) & \text{otherwise.} \end{cases}$$

- 3.2. NOTATION. (i) The transitive reflexive closure of ' $\longrightarrow$ ' will be denoted by ' $\longrightarrow$ '.
- (ii) If (C,L)  $\longrightarrow$  (C,L'), we will say: (C,L) reduces in one step to (C,L'). For brevity we will sometimes write L  $\longrightarrow$  L'.
- 3.3. <u>DEFINITION</u>. (i) A labeled circuit (C,L) is <u>in normal form</u> iff no reduction rule applies to it. (C,L) <u>has</u> a normal form iff (C,L)  $\longrightarrow$  (C,L') for some L' such that (C,L') is in normal form.
- (ii) (C,L) is unambiguous if it has precisely one normal form.
- (iii) (C,L) is stable if it is correct and in normal form.
- (iv) (C,L) is  $\underline{\text{inconsistent}}$  if it has an incorrect normal form.

We will now consider whether it is possible to reduce a labeled circuit to a normal form, and whether such a normal form is unique. We start with a simple observation.

3.4. PROPOSITION. Every labeled circuit (C,L) has a normal form. Moreover, every reduction of (C,L) must end in a normal form.

PROOF. In every reduction step the number of occurrences of 0,1 increases. (In the restoring logic reduction rule, this is so because we required there L'  $\neq$  L'.) Furthermore, occurrences of 0 and 1 are permanent. Since W(C) is finite, the proposition follows.  $\square$ 

3.5. <u>LEMMA</u>. Let  $(C,L_0)$  be a <u>consistent</u> labeled circuit (not necessarily correct), and suppose that  $(C,L_0) \longrightarrow (C,L_1)$  and  $(C,L_0) \longrightarrow (C,L_2)$ . Then there is a labeling  $L_3$  such that  $(C,L_1) \longrightarrow (C,L_3)$  for i = 1,2.



PROOF. We will distinguish redexes of type (1), (2) or (3), according to the rules in Definition 3.1 (i.e. (1): input reduction rules, (2): switch reduction rules, and (3): restoring logic reduction rule).

If the two redexes  $(R_i, L_i) \subseteq (C, L_0)$  which are reduced in the steps  $(C,L_0) \longrightarrow (C,L_i)$  (i = 1,2), are <u>disjoint</u> (in an obvious sense) then the statement in the lemma is evidently true. Likewise if  $(R_1, L_1)$  and  $(R_2, L_2)$ are identical (as subcircuit occurrences). Otherwise the following cases arise.

Case 1. The two redexes are both (1)-redexes. This can only be the case if they are disjoint or identical.

Case 2.  $(R_1,L_1)$  is a (1)-redex and  $(R_2,L_2)$  is a (2)-redex.



A case as e.g. 0 1 1 cannot arise, since (C,L<sub>0</sub>) is consistent.

For, this subcircuit reduces either to 0 0 1 or to 0 1

and during every further reduction this configuration stays the same. In particular, any normal form of  $(C,L_0)$  is incorrect, whence  $(C,L_0)$  is inconsistent.

The other cases of the type: (1)-redex versus (2)-redex are analogous. Case 3.  $(R_1,L_1)$  and  $(R_2,L_2)$  are both (2)-redexes. A typical example:



which leads to the common reduct consisting of the same circuit with 0 replaced by 1.



cannot occur since such a configuration reduces to a permanent (i.e. in every further reduction) incorrect labeled circuit (viz. the same subcircuit where l is replaced by either 0 or 1).

The other cases of this type, (2) versus (2), are similar.

Case 4. (2) versus (3).

- (a) If the (2)-redex  $(R_1,L_1)$  is part of the (3)-redex  $(R_2,L_2)$ , there is no problem, due to the correctness requirement in a (3)-redex.
- (b) Otherwise we have e.g. the following situation:



Several subcases arise according to the values of a and  $\overline{L_2}(a)$ . We will treat some typical subcases. The most interesting case of this proof is subcase (iii) .

(i) i = 0 and  $\overline{L_2}$  (a) = 0: the circuit is inconsistent.

(ii) i = 0 and  $\overline{L_2}(a) = 1$  or 1: cannot happen, since in a correct labeling (in casu  $L_2$ ) values can only be restored.

(iii) i = 0 and  $L_{2}(a) = 0$ .

CLAIM: the common reduct is



<u>Proof of the claim</u>: Let  $(R_2^*, L_2^*)$  be the subcircuit of  $(R_2, L_2)$  obtained by removing a and the switches connected to a;  $L_2^*$  is  $L_2$  restricted to  $R_2^*$ . Clearly,  $(R_2^{\star}, L_2^{\star})$  is also a (3)-redex, that is,  $L_2^{\star}$  is correct. Reducing this (3)-redex yields  $(R_2^*, \overline{L_2^*})$ . Adding a, the switches connected to a and the labeling a0 again, results in  $(R_2, \overline{L_2})$ , because in the proof  $L_2 - \overline{L_2}$ the value a0 cannot be used, and also switches S(b,c;(-)a) cannot appear in the proof  $L_2 \vdash L_2$ .

To reach the common reduct we only have to replace in  $(R_2, \overline{L_2})$  the value a0 by all.

The remaining cases for this type: (2) vs (3) are similar.

Case 5. (1) versus (3).

If the (1)-redex  $(R_1,L_1)$  is a part of the (3)-redex  $(R_2,L_2)$  there is no problem, since L<sub>j</sub>is correct. Otherwise we have a situation like



and this is analogous to subcase 4b(iii) above.

Case 6. (3) versus (3). This last case is easy: let  $(R_1, L_1)$  and  $(R_2, L_2)$  be both (3)-redexes. Let  $(R_1 \cup R_2, L_1 \cup L_2)$  denote the result of combining the

two subcircuits into one subcircuit. Clearly  $L_1 \cup L_2$  is again correct. Then  $(R_1 \cup R_2, \overline{L_1 \cup L_2})$  is a common reduct of  $(R_1 \cup R_2, \overline{L_1 \cup L_2})$  and  $(R_1 \cup R_2, \overline{L_1 \cup \overline{L_2}})$ .

- 3.6. <u>REMARK</u>. Proposition 3.4 can be rephrased, in a well-known terminology, as stating that the reduction '----' has the Strong Normalization (SN) (or Strong Termination) property. Lemma 3.5 says that '------' is weakly confluent, or: has the weak Church-Rosser property (WCR). Combining these two properties we have the
- 3.7. UNIQUE EVALUATION THEOREM. Let (C,L) be a consistent labeled circuit. Then (C,L) is unambiguous. Moreover, every reduction of (C,L) terminates eventually in the unique normal form.

<u>PROOF</u>. A direct consequence of SN and WCR for ' $\longrightarrow$ ', via 'Newman's Lemma' (see e.g. [2]).

3.8. EXAMPLE. This example shows that an inconsistent (C,L) may have several correct normal forms. Let C be the circuit:



Now let (C,L) be: (a,b,c,d,e) = (0,1,1,0,0), a correct initial labeling. Then  $(C,L^-)$  is: (a,b,c,d,e) = (0,1,1,0,0), the weakened labeling. Let  $(C',L^-)$  be: (a,b,c,d,e) = (1,1,1,0,0), change of input a.  $(C',L^-)$  reduces to (a,b,c,d,e) = (1,1,1,1,0), a correct normal form. (Apply the restoring logic reduction rule on the left 'cycle', followed by an application of a switch reduction rule.) Likewise  $(C',L^-)$  reduces to

$$(a,b,c,d,e) = (1,1,0,0,0)$$

by applying the restoring logic rule first on the right 'cycle'. Finally, by an application of this rule on both cycles simultaneously, we obtain the incorrect normal form  $(a,b,c,d,e) = (\hat{1},\hat{1},\hat{1},0,0)$ .

3.9. EXAMPLE. Let circuits 'AND' and 'OR' be defined as follows:



(the  $'\longrightarrow$  ' arrows denote input and output ports).

Let C be the circuit



Now (a,b,c,d) = (0,1,0,1) is a stable labeling. After weakening to (0,1,0,1) and changing the inputs (a,b) simultaneously to (1,0) we obtain (1,0,0,1), an incorrect normal form.

(If the inputs (a,b) are changed sequentially to (1,0), the result is either (1,0,1,1) in case a is first changed, or (1,0,0,0) in case b is first changed. Both labelings are stable.)

3.10. EXAMPLE. This example occurs in HOPCROFT & ULLMAN [1] (as Exercise 2.1, p.46, solution on p.52), where it is asked to analyze the dynamic behaviour. However, the circuit with the correct labeling as displayed below in diagram (a) is inconsistent after weakening and changing the value of the input a to 0. We then have the labeling as in diagram (b). (See next page.)



## Diagram (b):



This labeling is an incorrect normal form. In [1], p.52 an intuitive procedure is sketched to reach from this labeling a correct normal form: take the values for  $y_1, y_2$  (i.e. 0,1) and "compute further" till stabilization occurs. Then  $(y_1, y_2, z_1, z_2)$  will be (1,1,0,1). However, if  $z_1, z_2$  is taken as starting point for this intuitive stabilization, then the result is (0,0,0,0). Our reduction procedure does not suffer from this ambiguity, since the labeled circuit in diagram (b) is rejected as being inconsistent.

The essential difficulty of this circuit is already present in the subcircuit indicated by the rectangle above, which was considered in Example 3.9.

We are now in a position to describe the effects of an input modification:

- (1) Let circuit C be given with a correct labeling L.
- (2) Weaken L to L.
- (3) Modify CO, C1. Result: a circuit C' with C'O,C'1.
  (Note: the underlying circuit, i.e. C without specification of CO, C1 has of course remained the same in C'.)
- (4) (C',L) is now an incorrectly labeled circuit, which is not in normal form. If (C',L) is inconsistent, i.e. has an incorrect

normal form, the circuit is disqualified. Otherwise:

(5) Reduce (C',L') to the unique correct normal form (C',L').

In the next section we will apply the reduction system and the procedure defined above to analyze the behaviour of the Muller C-circuit. We will close this section with two definitions, for which we need the concept of an I/O-circuit (input/output circuit). Up to here, it was (deliberately) not specified for a circuit which channels where the input and output channels. (In the Appendix we will deal with this question,) Let us assume in advance that an I/O-circuit is defined. Then we define

- 3.11. <u>DEFINITION</u>. (i) Let C be an I/O-circuit. C is called <u>fully consistent</u> if for every possible assignment of values 0,1 to the input channels and every correct labeling L extending this input assignment, the resulting labeled circuit (C,L) is consistent.
- (ii) Let (C,L) be a correctly labeled I/O-circuit. Then (C,L) is <u>fully restoring</u> if it is consistent and the values of the output channels in the unique normal form (C,L') are 0 or 1.

## 4. AN EXAMPLE IN DETAIL: THE MULLER C-ELEMENT

We will now apply the reduction system in Section 3 to derive the behaviour of the Muller C-circuit, as shown in the Introduction. The circuit has inputs a,b and outputs c,d.

- (1) Start with (a,b) = (0,0) and the correct labeling  $L_1$  shown in diagram 1 below (the value of f is arbitrary). Replace (a,b) by (0,1) after weakening  $L_1$  to  $L_1$ , as in diagram 2.
- (2) The enclosed subcircuit (C',L') in diagram 2 is correctly labeled. Using the restoring logic rule (2.IV) we prove:

Likewise we prove that <u>all</u> values in the subcircuit C' are made restoring in  $L'_2$ .

Now the restoring logic reduction rule enables us to substitute these restored values instead. This yields  $(C', \overline{L_2'})$ . From this labeling we prove

$$\frac{g1}{f1} \qquad \text{and} \qquad \frac{m0}{n0}$$

thus arriving at a stable position  $L_2$ .

(3) Now change (a,b) to, say, (1,1), after weakening  $L_2$  to  $L_2$ . Then we arrive at the stable position  $L_3$  in diagram 3, without using this time the restoring logic (reduction) rule. Note the non-restoring no.

Continuing this analysis we find the (expected) behaviour of the Muller C-circuit as in the transition diagram 4 below. Here the 4-tuples indicate the value of (a,b,c,d). (The dotted lines denote a <u>simultaneous</u> change of the input values a,b.) Note that the circuit is fully restoring: i.e. the output values are always restoring. Also the circuit is fully consistent. The circuit has six stable positions, not taking into account the values of f and n which are irrelevant in some labelings.





Diagram 4:



### APPENDIX: INPUTS AND OUTPUTS

For a circuit C we are interested in deciding which wires can serve as inputs and which ones can serve as outputs. Already in the simple case of one switch a b it is clear that the situation is not straightforward:

- (i) if a is an input, b is not;
- (ii) if b is an input, then a is not;
- (iii) c is not an output.

Let  $(C, \overrightarrow{a}, \overrightarrow{b})$  be a circuit C together with a specification of disjoint sets  $\overrightarrow{a}, \overrightarrow{b} \in W(C)$ . Here  $\overrightarrow{a} = a_1, \dots, a_n$  and  $\overrightarrow{b} = b_1, \dots, b_m$ . Furthermore we employ the following

NOTATIONS. (i)  $\mathcal{L}$  is the set of correct {0,1}-labelings of C. (ii)  $\mathcal{J} = \{0,1\}^n$  is the set of n-tuples of restoring values 0,1 (which will serve as assignments to  $\overrightarrow{a} = a_1, \dots, a_n$ ).

(iii) For  $L \in \mathcal{L}$  and  $\alpha = (\alpha(1), \dots, \alpha(n)) \in \mathcal{J}$  we write  $L[\alpha]$  to denote L relabeled by  $\alpha$  on  $\overrightarrow{a}$ , that is:

$$(L[\alpha])(a_i) = \alpha(i) \quad (i = 1,...,n)$$
  
 $(L[\alpha])(c) = L(c) \text{ if } c \notin \overrightarrow{a}.$ 

(iv) If L[ $\alpha$ ] is <u>consistent</u>, it has a unique normal form which is denoted by NF(L, $\alpha$ ). Further, F(L, $\alpha$ ) = NF(L, $\alpha$ ). Note that F: $\mathcal{L}x\mathcal{J} \to \mathcal{L}$  (i.e. F(L, $\alpha$ ) is again correct).

Now we can state the definition of input and output ports:

<u>DEFINITION</u>. Let  $(C, \vec{a}, \vec{b})$ ,  $\mathcal{L}$ ,  $\mathcal{J}$  be as described. Suppose for all  $L \in \mathcal{L}$ ,  $\alpha \in \mathcal{J}$ :

- (i)  $L[\propto]$  is consistent
- (ii) NF(L, $\alpha$ ) (b<sub>j</sub>)  $\in \{0,1\}$  (j = 1,...,m).

Then  $(C, \vec{a}, \vec{b})$  is called a restoring I/O-circuit with input ports  $\vec{a}$  and output ports  $\vec{b}$ .

### REFERENCES

- [1] HOPCROFT, J.E. & J.D. ULLMAN

  Introduction to automata theory, languages, and computation.

  Addison-Wesley, Reading, Mass.(1979)
- [2] KLOP, J.W.

  <u>Combinatory Reduction Systems</u>,

  <u>Mathematical Centre Tracts 127</u>, Mathematisch Centrum, Amsterdam 1980.
- [3] KOHAVI, Z.

  <u>Switching and finite automata theory</u>,

  McGraw-Hill, New York (1970)
- [4] MEAD, C, & L. CONWAY

  Introduction to VLSI systems,
  Addison-Wesley, Reading, Mass.(1980)
- [5] MILLER, R.E.

  <u>Switching Theory</u>, Vol.2

  New York, Wiley (1965)
- [6] REM, M.

  Partially ordered computations, with applications to VLSI design,
  To appear in the Proc. of the 4th Advanced Courde on Foundations of Computer Science, Amsterdam, June 1982.
- [7] REM, M. & C. MEAD A notation for designing restoring logic circuitry in CMOS, Proc. 2nd Caltech Conference on VLSI, ed. C.L. Seitz, California Institute of Technology, Pasadena, California 1981.